import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import {
	login,
	logout,
	getInfo,
	getSimple
} from '@/api/login'
import {
	setToken,
	removeToken
} from '@/utils/auth'

const baseUrl = config.baseUrl

const user = {
	state: {
		user_id: storage.get(constant.user_id), // 用户编号
		name: storage.get(constant.name),
		avatar: storage.get(constant.avatar),
		roles: storage.get(constant.roles),
		menus: storage.get(constant.menus),
		dict: storage.get(constant.dict),
		users: storage.get(constant.users)
	},

	mutations: {
		SET_ID: (state, id) => {
			state.user_id = id
			storage.set(constant.user_id, id)
		},
		SET_NAME: (state, name) => {
			state.name = name
			storage.set(constant.name, name)
		},
		SET_AVATAR: (state, avatar) => {
			state.avatar = avatar
			storage.set(constant.avatar, avatar)
		},
		SET_ROLES: (state, roles) => {
			state.roles = roles
			storage.set(constant.roles, roles)
		},
		SET_PERMISSIONS: (state, permissions) => {
			state.permissions = permissions
			storage.set(constant.permissions, permissions)
		},
		SET_MENUS: (state, menus) => {
			state.menus = menus
			storage.set(constant.menus, menus)
		},
		SET_DICT: (state, dict) => {
			state.dict = dict
			storage.set(constant.dict, dict)
		},
		SET_USERS: (state, users) => {
			state.users = users
			storage.set(constant.users, users)
		}
	},

	actions: {
		// 登录
		Login({
			commit,
			dispatch
		}, userInfo) {
			const username = userInfo.username.trim()
			const password = userInfo.password
			const captchaVerification = userInfo.captchaVerification
			return new Promise((resolve, reject) => {
				login(username, password, captchaVerification).then(res => {
					// 设置 token
					setToken(res)
					dispatch('GetInfo', {
						commit
					});
					dispatch('simple', {
						commit
					});
					resolve()
				}).catch(error => {
					reject(error)
				})
			})
		},

		// 获取用户信息
		GetInfo({
			commit,
			state
		}) {
			return new Promise((resolve, reject) => {
				getInfo().then(res => {
					//res = res.data; // 读取 data 数据
					const user = res.user
					console.log('user', user)
					const avatar = (user == null || user.avatar === "" || user.avatar == null) ?
						require("@/static/images/profile.jpg") : user.avatar
					const nickname = (user == null || user.nickname === "" || user.nickname ==
						null) ? "" : user.nickname
					if (res.roles && res.roles.length > 0) {
						commit('SET_ROLES', res.roles)
						commit('SET_PERMISSIONS', res.permissions)
					} else {
						commit('SET_ROLES', ['ROLE_DEFAULT'])
					}
					commit('SET_MENUS', res.menus)
					commit('SET_USERS', user)
					commit('SET_ID', user.id)
					commit('SET_NAME', nickname)
					commit('SET_AVATAR', avatar)
					resolve(res)
				}).catch(error => {
					reject(error)
				})
			})
		},
		// 退出系统
		LogOut({
			commit,
			state
		}) {
			let that = this;
			return new Promise((resolve, reject) => {
				logout(state.token).then(() => {
					commit('SET_ROLES', [])
					commit('SET_PERMISSIONS', [])
					removeToken()
					storage.clean()
					resolve()
				}).catch(error => {
					reject(error)
				})
			})
		}
	}
}

export default user